/**
 * 通用js方法封装处理
 * Copyright (c) 2019 ruoyi
 */
import {Exception} from "sass";


// 日期格式化
export function parseTime(time, pattern) {
  if (arguments.length === 0 || !time) {
    return null
  }
  const format = pattern || '{y}-{m}-{d} {h}:{i}:{s}'
  let date
  if (typeof time === 'object') {
    date = time
  } else {
    if ((typeof time === 'string') && (/^[0-9]+$/.test(time))) {
      time = parseInt(time)
    } else if (typeof time === 'string') {
      time = time.replace(new RegExp(/-/gm), '/').replace('T', ' ').replace(new RegExp(/\.[\d]{3}/gm), '');
    }
    if ((typeof time === 'number') && (time.toString().length === 10)) {
      time = time * 1000
    }
    date = new Date(time)
  }
  const formatObj = {
    y: date.getFullYear(),
    m: date.getMonth() + 1,
    d: date.getDate(),
    h: date.getHours(),
    i: date.getMinutes(),
    s: date.getSeconds(),
    a: date.getDay()
  }
  const time_str = format.replace(/{(y|m|d|h|i|s|a)+}/g, (result, key) => {
    let value = formatObj[key]
    // Note: getDay() returns 0 on Sunday
    if (key === 'a') { return ['日', '一', '二', '三', '四', '五', '六'][value] }
    if (result.length > 0 && value < 10) {
      value = '0' + value
    }
    return value || 0
  })
  return time_str
}

// 表单重置
export function resetForm(refName) {
  if (this.$refs[refName]) {
    this.$refs[refName].resetFields();
  }
}

// 添加日期范围
export function addDateRange(params, dateRange, propName) {
  let search = params;
  search.params = typeof (search.params) === 'object' && search.params !== null && !Array.isArray(search.params) ? search.params : {};
  dateRange = Array.isArray(dateRange) ? dateRange : [];
  if (typeof (propName) === 'undefined') {
    search.params['beginTime'] = dateRange[0];
    search.params['endTime'] = dateRange[1];
  } else {
    search.params['begin' + propName] = dateRange[0];
    search.params['end' + propName] = dateRange[1];
  }
  return search;
}

// 回显数据字典
export function selectDictLabel(datas, value) {
  if (value === undefined) {
    return "";
  }
  var actions = [];
  Object.keys(datas).some((key) => {
    if (datas[key].value == ('' + value)) {
      actions.push(datas[key].label);
      return true;
    }
  })
  if (actions.length === 0) {
    actions.push(value);
  }
  return actions.join('');
}

// 回显数据字典（字符串数组）
export function selectDictLabels(datas, value, separator) {
  if (value === undefined || value.length ===0) {
    return "";
  }
  if (Array.isArray(value)) {
    value = value.join(",");
  }
  var actions = [];
  var currentSeparator = undefined === separator ? "," : separator;
  var temp = value.split(currentSeparator);
  Object.keys(value.split(currentSeparator)).some((val) => {
    var match = false;
    Object.keys(datas).some((key) => {
      if (datas[key].value == ('' + temp[val])) {
        actions.push(datas[key].label + currentSeparator);
        match = true;
      }
    })
    if (!match) {
      actions.push(temp[val] + currentSeparator);
    }
  })
  return actions.join('').substring(0, actions.join('').length - 1);
}

// 字符串格式化(%s )
export function sprintf(str) {
  var args = arguments, flag = true, i = 1;
  str = str.replace(/%s/g, function () {
    var arg = args[i++];
    if (typeof arg === 'undefined') {
      flag = false;
      return '';
    }
    return arg;
  });
  return flag ? str : '';
}

// 转换字符串，undefined,null等转化为""
export function parseStrEmpty(str) {
  if (!str || str == "undefined" || str == "null") {
    return "";
  }
  return str;
}

// 数据合并
export function mergeRecursive(source, target) {
  for (var p in target) {
    try {
      if (target[p].constructor == Object) {
        source[p] = mergeRecursive(source[p], target[p]);
      } else {
        source[p] = target[p];
      }
    } catch (e) {
      source[p] = target[p];
    }
  }
  return source;
};

/**
 * 构造树型结构数据
 * @param {*} data 数据源
 * @param {*} id id字段 默认 'id'
 * @param {*} parentId 父节点字段 默认 'parentId'
 * @param {*} children 孩子节点字段 默认 'children'
 */
export function handleTree(data, id, parentId, children) {
  let config = {
    id: id || 'id',
    parentId: parentId || 'parentId',
    childrenList: children || 'children'
  };

  var childrenListMap = {};
  var nodeIds = {};
  var tree = [];

  for (let d of data) {
    let parentId = d[config.parentId];
    if (childrenListMap[parentId] == null) {
      childrenListMap[parentId] = [];
    }
    nodeIds[d[config.id]] = d;
    childrenListMap[parentId].push(d);
  }

  for (let d of data) {
    let parentId = d[config.parentId];
    if (nodeIds[parentId] == null) {
      tree.push(d);
    }
  }

  for (let t of tree) {
    adaptToChildrenList(t);
  }

  function adaptToChildrenList(o) {
    if (childrenListMap[o[config.id]] !== null) {
      o[config.childrenList] = childrenListMap[o[config.id]];
    }
    if (o[config.childrenList]) {
      for (let c of o[config.childrenList]) {
        adaptToChildrenList(c);
      }
    }
  }
  return tree;
}

/**
* 参数处理
* @param {*} params  参数
*/
export function tansParams(params) {
  let result = ''
  for (const propName of Object.keys(params)) {
    const value = params[propName];
    var part = encodeURIComponent(propName) + "=";
    if (value !== null && value !== "" && typeof (value) !== "undefined") {
      if (typeof value === 'object') {
        for (const key of Object.keys(value)) {
          if (value[key] !== null && value[key] !== "" && typeof (value[key]) !== 'undefined') {
            let params = propName + '[' + key + ']';
            var subPart = encodeURIComponent(params) + "=";
            result += subPart + encodeURIComponent(value[key]) + "&";
          }
        }
      } else {
        result += part + encodeURIComponent(value) + "&";
      }
    }
  }
  return result
}


// 返回项目路径
export function getNormalPath(p) {
  if (p.length === 0 || !p || p == 'undefined') {
    return p
  };
  let res = p.replace('//', '/')
  if (res[res.length - 1] === '/') {
    return res.slice(0, res.length - 1)
  }
  return res;
}

// 验证是否为blob格式
export function blobValidate(data) {
  return data.type !== 'application/json'
}

export const fileFunction = {
  /**
   * 格式化文件大小
   * @param {number} size 文件大小
   * @param {boolean} isInteger 是否只显示整数位，默认不截取
   * @returns {string} 文件大小（带单位）
   */
  calculateFileSize(size, isInteger = false) {
    const B = 1024
    const KB = Math.pow(1024, 2)
    const MB = Math.pow(1024, 3)
    const GB = Math.pow(1024, 4)
    if (isInteger) {
      // 截取为整数
      if (size < B) {
        return `${size}B`
      } else if (size < KB) {
        return `${(size / B).toFixed(0)}KB`
      } else if (size < MB) {
        return `${(size / KB).toFixed(0)}MB`
      } else if (size < GB) {
        return `${(size / MB).toFixed(0)}GB`
      } else {
        return `${(size / GB).toFixed(0)}TB`
      }
    } else {
      // 保留小数位
      if (size < B) {
        return `${size}B`
      } else if (size < KB) {
        return `${(size / B).toFixed(0)}KB`
      } else if (size < MB) {
        return `${(size / KB).toFixed(1)}MB`
      } else if (size < GB) {
        return `${(size / MB).toFixed(2)}GB`
      } else {
        return `${(size / GB).toFixed(3)}TB`
      }
    }
  },
  /**
   * 获取流式的缩略图、视频封面图
   * @param {object} row 文件信息
   * @returns {string} 流式图片
   */
  getMinImgStream(row) {
    return `${config.baseContext}/filetransfer/preview?userFileId=${
        row.userFileId
    }&isMin=true&shareBatchNum=${
        row.shareBatchNum == null ? '' : row.shareBatchNum
    }&extractionCode=${row.extractionCode == null ? '' : row.extractionCode}`
  },
  /**
   * 获取文件查看路径
   * @param {object} row 文件信息
   * @returns {string} 文件路径
   */
  getViewFilePath(row) {
    return `${config.baseContext}/filetransfer/preview?userFileId=${
        row.userFileId
    }&isMin=false&shareBatchNum=${
        row.shareBatchNum == null ? '' : row.shareBatchNum
    }&extractionCode=${row.extractionCode == null ? '' : row.extractionCode}`
  },
  /**
   * 获取文件下载路径
   * @param {object} row 文件信息
   * @returns {string}  文件下载路径
   */
  getDownloadFilePath(row) {
    return `${config.baseContext}/filetransfer/downloadfile?userFileId=${
        row.userFileId
    }&shareBatchNum=${
        row.shareBatchNum == null ? '' : row.shareBatchNum
    }&extractionCode=${row.extractionCode == null ? '' : row.extractionCode}`
  },
  /**
   * 获取 Onlyoffice 文件创建路径
   * @param {object} row
   * @returns {string} office 文件创建路径
   */
  createFileOnlineByOffice(data) {
    let fileUrl = `${location.protocol}//${location.host}${config.baseContext}`
    const { href } = router.resolve({
      name: 'Onlyoffice',
      query: {
        fileUrl: fileUrl,
        fileName: data.fileName,
        filePath: data.filePath,
        extendName: data.extendName,
        ot: 'add'
      }
    })
    window.open(href, '_blank')
  },
  /**
   * 获取 Onlyoffice 文件在线预览路径
   * @param {object} row
   * @returns {string} office 文件在线预览路径
   */
  getFileOnlineViewPathByOffice(row) {
    let userFileId = row.userFileId

    const { href } = router.resolve({
      name: 'Onlyoffice',
      query: {
        userFileId: userFileId,
        ot: 'detail'
      }
    })
    window.open(href, '_blank')
  },
  /**
   * 获取 Onlyoffice 文件在线编辑路径
   * @param {object} row
   * @returns {string} office 文件在线编辑路径
   */
  getFileOnlineEditPathByOffice(row) {
    let userFileId = row.userFileId

    const { href } = router.resolve({
      name: 'Onlyoffice',
      query: {
        userFileId: userFileId,
        ot: 'edit'
      }
    })
    window.open(href, '_blank')
  },
  /**
   * 获取分享链接
   * @param {string} shareBatchNum
   * @returns {string} 完整的分享链接
   */
  getShareLink(shareBatchNum) {
    return `${location.protocol}//${location.host}/share/${shareBatchNum}`
  },
  /**
   * 复制分享链接
   * @param {string} shareBatchNum
   * @param {string} extractionCode
   */
  copyShareLink(shareBatchNum, extractionCode) {
    let input = document.createElement('textarea') // 直接构建textarea以保持换行
    input.value =
        extractionCode === null
            ? `分享链接：${this.getShareLink(
                shareBatchNum
            )}\n复制链接到浏览器中并输入提取码即可查看文件`
            : `分享链接：${this.getShareLink(
                shareBatchNum
            )}\n提取码：${extractionCode}\n复制链接到浏览器中并输入提取码即可查看文件` // 设置内容
    document.body.appendChild(input) // 添加临时实例
    input.select() // 选择实例内容
    document.execCommand('Copy') // 执行复制
    document.body.removeChild(input) // 删除临时实例
    Message.success('复制成功')
  },
  /**
   * 根据文件扩展名设置文件图片
   * @param {object} file 文件信息
   */
  setFileImg(file) {
    if (file.isDir === 1) {
      //  文件夹
      return fileImgMap.get('dir')
    } else if (
        Number(router.currentRoute.query.fileType) !== 6 &&
        ['jpg', 'png', 'jpeg', 'gif', 'mp4'].includes(
            file.extendName.toLowerCase()
        )
    ) {
      // 图片、视频类型，直接显示缩略图
      return this.getMinImgStream(file)
    } else if (fileImgMap.has(file.extendName.toLowerCase())) {
      // 可以识别文件类型的文件
      return fileImgMap.get(file.extendName.toLowerCase())
    } else {
      // 无法识别文件类型的文件
      return unknownImg
    }
  },
  /**
   * 判断是否是视频文件
   * @param {object} file 文件信息
   */
  isVideoFile(file) {
    if (
        ['avi', 'mp4', 'mpg', 'mov', 'swf'].includes(
            file.extendName?.toLowerCase()
        )
    ) {
      return true
    } else {
      return false
    }
  },
  /**
   * 图片预览
   * @param {*} currentIndex 当前图片索引
   * @param {*} imgInfo 单个图片信息
   * @param {*} imgInfoList 多个图片列表
   */
  handleImgPreview(currentIndex, imgInfo = {}, imgInfoList = []) {
    // 图片分类下 - 传递整个页面的图片列表；非图片分类下 - 由单个图片构建图片列表
    const imgList =
        Number(router.currentRoute.query.fileType) === 1
            ? imgInfoList.map((item) => {
              return {
                ...item,
                fileUrl: this.getViewFilePath(item),
                downloadLink: this.getDownloadFilePath(item)
              }
            })
            : [
              {
                ...imgInfo,
                fileUrl: this.getViewFilePath(imgInfo),
                downloadLink: this.getDownloadFilePath(imgInfo)
              }
            ]
    const defaultIndex =
        Number(router.currentRoute.query.fileType) === 1 ? currentIndex : 0
    Vue.prototype.$openBox.imgPreview({ imgList, defaultIndex })
  },
  /**
   * 视频预览
   * @param {*} currentIndex 当前视频索引
   * @param {*} videoInfo 单个视频信息
   * @param {*} videoInfoList 多个视频列表
   */
  handleVideoPreview(currentIndex, videoInfo = {}, videoInfoList = []) {
    // 视频分类下 - 传递整个页面的视频列表；非视频分类下 - 由单个视频构建视频列表
    const videoList =
        Number(router.currentRoute.query.fileType) === 3
            ? videoInfoList.map((item) => {
              return {
                ...item,
                fileUrl: this.getViewFilePath(item),
                downloadLink: this.getDownloadFilePath(item)
              }
            })
            : [
              {
                ...videoInfo,
                fileUrl: this.getViewFilePath(videoInfo),
                downloadLink: this.getDownloadFilePath(videoInfo)
              }
            ]
    const defaultIndex =
        Number(router.currentRoute.query.fileType) === 3 ? currentIndex : 0
    Vue.prototype.$openBox.videoPreview({ videoList, defaultIndex })
  },
  /**
   * 音频预览
   * @param {*} currentIndex 当前音频索引
   * @param {*} audioInfo 单个音频信息
   * @param {*} audioInfoList 多个音频列表
   */
  handleAudioPreview(currentIndex, audioInfo = {}, audioInfoList = []) {
    // 音频分类下 - 传递整个页面的音频列表；非音频分类下 - 由单个音频构建音频列表
    const audioList =
        Number(router.currentRoute.query.fileType) === 4
            ? audioInfoList.map((item) => {
              return {
                ...item,
                fileUrl: this.getViewFilePath(item),
                downloadLink: this.getDownloadFilePath(item)
              }
            })
            : [
              {
                ...audioInfo,
                fileUrl: this.getViewFilePath(audioInfo),
                downloadLink: this.getDownloadFilePath(audioInfo)
              }
            ]
    const defaultIndex =
        Number(router.currentRoute.query.fileType) === 4 ? currentIndex : 0
    Vue.prototype.$openBox.audioPreview({ audioList, defaultIndex })
  },
  /**
   * 文件预览
   * @description 若当前点击的为文件夹，则进入文件夹内部；若是文件，则进行相应的预览。
   * @param {object} row 文件信息
   * @param {number} currentIndex 当前文件索引
   * @param {array} fileList 文件列表
   */
  handleFileNameClick(row, currentIndex, fileList = []) {
    // 如果当前文件在回收站中，则不允许预览
    if (row.deleteFlag !== undefined && row.deleteFlag !== 0) {
      return false
    }
    // 若是文件夹则进入该文件夹
    if (row.isDir) {
      if (router.currentRoute.name === 'Share') {
        // 当前是查看他人分享列表的页面
        router.push({
          query: {
            filePath: `${row.shareFilePath === '/' ? '' : row.shareFilePath}/${
                row.fileName
            }`
          }
        })
      } else if (Number(router.currentRoute.query.fileType) === 8) {
        // 当前是我的已分享列表页面
        router.push({
          query: {
            fileType: 8,
            filePath: `${row.shareFilePath === '/' ? '' : row.shareFilePath}/${
                row.fileName
            }`,
            shareBatchNum: row.shareBatchNum
          }
        })
      } else if (Number(router.currentRoute.query.fileType) !== 6) {
        // 回收站页面不允许打开文件夹
        // 网盘页面
        router.push({
          query: {
            filePath: `${row.filePath === '/' ? '' : row.filePath}/${
                row.fileName
            }`,
            fileType: 0
          }
        })
      }
    }
    // 若是文件，则进行相应的预览
    else {
      // 若当前点击项是图片
      const PIC = ['png', 'jpg', 'jpeg', 'gif', 'svg']
      if (PIC.includes(row.extendName.toLowerCase())) {
        this.handleImgPreview(currentIndex, row, fileList)
        return false
      }
      //  若当前点击项是可以使用office在线预览的
      if ([...officeFileType].includes(row.extendName.toLowerCase())) {
        this.getFileOnlineViewPathByOffice(row)
        return false
      }
      //  若当前点击项是pdf
      if (row.extendName.toLowerCase() === 'pdf') {
        window.open(this.getViewFilePath(row), '_blank')
      }
      //  若当前点击项是代码或文本文件
      let codeFileSuffix = row.extendName.toLowerCase()
      if (codeFileSuffix === 'yaml') {
        codeFileSuffix = 'yml'
      }
      // 无格式文件也可以在线编辑
      if (
          fileSuffixCodeModeMap.has(codeFileSuffix) ||
          (row.isDir === 0 && row.extendName === '')
      ) {
        Vue.prototype.$openBox.codePreview({ fileInfo: row, isEdit: false })
        return false
      }
      //  若当前点击项是 markdown 文档
      if (markdownFileType.includes(row.extendName.toLowerCase())) {
        Vue.prototype.$openBox.markdownPreview({
          fileInfo: row,
          editable: false
        })
        return false
      }
      //  若当前点击项是视频mp4格式
      const VIDEO = ['mp4']
      if (VIDEO.includes(row.extendName.toLowerCase())) {
        this.handleVideoPreview(currentIndex, row, fileList)
        return false
      }
      //  若当前点击项是音频 mp3、flac 格式
      const AUDIO = ['mp3', 'flac']
      if (AUDIO.includes(row.extendName.toLowerCase())) {
        this.handleAudioPreview(currentIndex, row, fileList)
        return false
      }
    }
  },
  /**
   * 文件名称拼接，包括文件名称 + 文件后缀
   * @param {object} file 文件信息
   * @param {boolean} isHighlight 是否需要展示高亮效果，默认不需要
   * @returns {string} 完整文件名称
   */
  getFileNameComplete(file, isHighlight = false) {

  },
  /**
   * 文件类型
   * @param {object} file 文件信息
   */
  getFileType(file) {
    return file.isDir === 1
        ? '文件夹'
        : file.extendName
            ? file.extendName
            : '文件'
  },
  /**
   * 获取文件分享过期状态
   * @param {string} time 日期
   * @returns {boolean} 是否过期
   */
  getFileShareStatus(time) {
    if (new Date(time).getTime() > new Date().getTime()) {
      return false
    } else {
      return true
    }
  },
  assetsItemType( row) {
    if ("folder" === row.objectType) {
      return row.objectType;
    }
    return row.type;
  },
  assetsName(objectType, title, ext) {
    if ("folder" === objectType) {
      return title;
    }
    return title + '.' + ext;
  },
  permissionName(permission){
    if(!permission){
      return "仅自己"
    }
    try{
      let obj = JSON.parse(permission);
      if(obj.value === "part") {
        return "部分可见"
      } else if (obj.value === "public") {
        return "公开"
      }
    } catch {
      return "未知";
    }
    return "仅自己"
  }
}

export function formatStr(str){
  const args = arguments;
  return str.replace(/{(\d+)}/g, function(match, number) {
    return typeof args[number] != 'undefined' ? args[number] : match;
  });
}
